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FINALTERM EXAMINATION 2010 
Question No:1 
name of two divide and conquer algorithm (2 marks) 
Answer:- (Page 488) 


“* Merge Sort 
** Quick Sort 
“* Heap Sort 


These three algorithms fall under ‘divide and conquer category’. 


Question No:2 

difference between call by value n call by reference (2 marks) 
Answer:- (Page 202) 
In case of call by value, a copy of object is made and placed at the time of function calling in the activation 
record. By using the references, we are not making the copy but send the address of the variable that function 
can use the original value. 


Question No:3 

heap and two types of heap(3) 
Answer:- (Page 333 ) 
Heap is a data structure of big use and benefit. It is used in priority queue. “The definition of heap is that it is a 
complete binary tree that conforms to the heap order”. Here heap order means the min and max heap. Max 
heap: In max heap, each node has a value greater than the value of its left and right child nodes. Moreover, the 
value of the root will be largest and will become lesser at downward levels. Min heap: in a (min) heap for 
every node X, the key in the parent is smaller than (or equal to) the key in X. This means that the value in the 
parent node is less than the value on its children nodes. 


Question No:4 
height of a tree is 5 find sum of heights (2) 
Answer:- 

Height = 5 
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Nodes = 24h = 245 =32 
Sum of Nodes = N-(h+1)= 32-(5+1) = 32-6 = 26 


Question No: 5 

Here is an array with exactly 15 elements: 

1234567891011 12131415. 

Suppose that we are doing a binary search for an element. Indicate any elements that will be found by 
examining two or fewer numbers from the array. (Marks: 5) 


Answer:- Click here for detail 

If there is an array of 15 elements, {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15} 

it wants to know which elements can be discovered by examining two or fewer elements. I want assume the 
divide and conquer aspect of a binary search, so that leads me to think these elements will be found 

1,2, 14, 15, 7,3 


rather; 1, 2, 3, 4, 6, 8, 14, 15 

1 and 15 for heads and tails 

2, and 14 for next elements (following or preceding) 
1/2 of 15 is either 6, or 8, from 7.5 

and 1/2 of 6 =3 

1/28=4 


Note: - I am not sure about answer; I feel Question logic is not clear. 


FINALTERM EXAMINATION 2010 


Q1 Write one example of hashing? 

Answer: (page 459) 

Hashing can be used to store the data. Suppose we have a list of fruits. The names of Fruits are in string. The 
key is the name of the fruit. We will pass it to the hash Function to get the hash key. 

HashCode ("apple") = 5 

We pass it to the string “apple”. Resultantly, it returns a number 5. 


Q2 Height of a tree is 5 find sum of heights 
Answer:- rep 


Q3 How do we carry out degeneration of Complete Binary Tree? 
Answer: Click here for detail 
Degeneration of the (original) binary tree is mainly reflected by degeneration of the internal infix trees and less 
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by degeneration of the external height of the PPbin tree. 


Q4 What is a skip List? 
Answer:- (Page 446) 
A skip list for a set S of distinct (key, element) items is a series of lists So, $1, ... , Sa such that 


¢ Each list Si contains the special keys +00 and -0o 
* List Socontains the keys of S in non-decreasing order 
*Each list is a subsequence of the previous one, i.e., 

So2 Si, 2 ... 2 Sh 
*List S, contains only the two special keys 


Q5 How we can generate a maze with the help of union 
Answer:- (Page 424) 
How can we generate maze? The algorithm is as follows: 
“* Randomly remove walls until the entrance and exit cells are in the same set. 
“* Removal of the wall is the same as doing a union operation. 


>, 


*“* Do not remove a randomly chosen wall if the cells it separates are already I the same set. 


Q7 Following is an array with exactly 15 elements: 
1234567891011 12131415. 
Suppose that we are doing a binary search for an element. Indicate any elements that will be found by 
examining two or fewer numbers from the array. 5 
Answer:- Repeat 


FINALTERM EXAMINATION 2010 


( Marks: 10 ) 

Write down the C++ code to implement insertion sort algorithm. 
Answer:- (Page 483) 

Following is the code of the insertion sort in C++. 

void insertionSort(int *arr, int N) 

{ 
int pos, count, val; 

for(count=1; count < N; count++) 
{ 
val = arr[count]; 
for(pos=count-1; pos >= 0; pos--) 
if (arr[pos] > val) 
arr[pos+1]=arr[pos]; 

else break; 

arr[pos+1] = val; 
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} 
} 


Q2. What is Table ADT? Discuss any two implementations of table ADT. ( Marks: 5) 
Answer:- (Page 427, 428) 

The table, an abstract data type, is a collection of rows and columns of information. 
Implementation of Table 

o Unsorted Sequential Array 


o Sorted Sequential Array 

Question No: 3 

Suppose we have the following representation for a complete Binary Search Tree, tell the Left and Right 
child nodes and Parent node of the node D ( Marks: 5) 
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Answer:- 

parent: B using formula(i/2) 
left child:-H 2i=2*4=8=H 
Right child:-I 2i+1=8+1=9=I 


Question No: 4 
.Consider the following max heap. Add node 24 in it and show the resultant Heap. ( Marks: 3 ) 


re 
~~ ) 2s 





Muhammad Moaaz Siddig — MCS (2nd) 


Campus:- Institute of E-Learning & Modern 
Studies (IEMS) Samundari 














Answer:- 





Question No:5 (Marks: 3 ) 

Here is an array of 10 integers. 

538170264. 

Draw this array after the first iteration of the large loop in a selection sort (Sorting from smallest to largest) 


Answer:- 








1" step 
2” step 
3" step 
4" step 
5"" step 
6"" step 
7” step 
8"" step 
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Question No: 6 (Marks: 3 ) 

What is an Equivalent relation? Give any two examples. 

Answer : (page 387) 

‘A binary relation R over a set S is called an equivalence relation if it has following properties’: 
1. Reflexivity: for all element x hS,xRx 

2. Symmetry: for all elements x and y, x R y if and only if y R x 

3. Transitivity: for all elements x, y and z, if x Ry andy RzthenxRz 

Example; sets of peoples ,electric circuit domain 
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Q7. What are the properties of equivalence class? 3marks 

Answer:- (Page 385) 

A binary relation R over a set S is called an equivalence relation if it has following Properties 
1.Reflexivity: for all element x € S,x Rx 

2. Symmetry: for all elements x and y, x R y if and only if y Rx 


3. Transitivity: for all elements x, y and z, ifx Ry andy Rz thenx Rz 


Q8. How heap sort works to set a set of data. 2Marks 

Answer:- (Page 334) 

Min heap and max heap are used to sort the data. Min heap convert the data in ascending sorted order and max 
heap convert the in descending order. 


Q9. How can we search an element in skip list? 2Marks 
Answer:- (Page 447) 


We search for a key x in the following fashion: 

We start at the first position of the top list 

¢ At the current position p, we compare x with y | key(after(p)) 

*x =y: we return element(after(p)) 

*x>y: we “scan forward” 

*x<y: we “drop down” 

¢ If we try to drop down past the bottom list, we return NO_SUCH_KEY 














Q10. What is an ADT? 
Answer:- (Page 428) 
The table, an abstract data type, is a collection of rows and columns of information. 


FINALTERM EXAMINATION 2010 


Question No: 27 = (Marks: 2 ) 
Give one example of Hashing 
Answer:- Repeated 


Question No: 28 (Marks: 2 ) 
How heap sort works to sort a set of data. 
Answer:- Repeated 


Question No: 29 (Marks: 2 ) 

How we can implement Table ADT using Linked? 

Answer:- (Page 441) 

List linked list is one choice to implement table abstract data type. For unsorted elements, the insertion at front 
operation will take constant time. But if the data inside the list is kept in sorted order then to insert a new 
element in the list, the entire linked list is traversed through to find the appropriate position for the element. 
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Question No: 30 (Marks: 2 ) 

If we allow assignment to constants what will happen? 

Answer:- (Page 8) 

Suppose ‘a’ has the value number 3. Now we assigned number 2 the number 3 i.e. all the number 2 will 
become number 3 and the result of 2 + 2 will become 6. Therefore it is not allowed. 


Question No: 31 (Marks: 3) 

Explain the process of Deletion in a Min-Heap 

Answer:- (Page 350) 

We have to write a function deleteMin(), which will find and delete the minimum number from the tree. 
Finding the minimum is easy; it is at the top of the heap. 


Question No: 32 (Marks: 3 ) 

Give any three characteristics of Union by Weight method. 

Answer:- (Page 408) 

Following are the salient characteristics of this method: 

** Maintain sizes (number of nodes) of all trees, and during union. 

Make smaller tree, the sub-tree of the larger one. 

** Implementation: for each root node i, instead of setting parent[i] to -1, set it to -k if tree rooted at i has k 
nodes. 


, , 
“Ww 4 


re 


Question No: 33 = ( Marks: 3 ) 

"For smaller lists, linear insertion sort performs well, but for larger lists, quick sort is suitable to apply." 
Justify why? 

Answer:- 

Since for smaller lists number of comparisons and interchange (if needed) decreases radically in insertion sort 
than quick sort. For larger lists, opposite occurs in both sorting techniques. 


Question No: 34 = (Marks: 5 ) 
Write down the C++ code to implement Insertion Sort Algorithm. 
Answer:- repeat 


Question No: 35 (Marks: 5 ) 
Consider the following Threaded Binary Tree, 
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You have to give the values that should be in the four variables given below, for the node 37 
1. LTH (Left flag) 
2. RTH (Right flag) 
3. Left node pointer (->L) 
4. Right node pointer (->R) 


Question No: 36 (Marks: 5 ) 

What is Disjoint Sets? Explain with an example. 

Answer:- (Page 388) 

Disjoint sets - Two sets are disjoint if they have no elements in common. 

Example:-Suppose there are many people around you. How can we separate those who are related to each other in 
this gathering? 

We make groups of people who are related to each other. The people in one group will say that they are related to 
each other. Similarly we can have many groups. So every group will say that they are related to each other with 
family relationship and there is no group that is related to any other group. The people in the group will say that 
there is not a single person in the other group who is related to them. 


FINALTERM EXAMINATION 2010 


Question No: 27 = ( Marks: 2 ) 

Give the difference between strict and complete binary tree. 

Answer:- (Page 121,123) 

A binary tree said to be a strictly binary tree if every non-leaf node in a binary has non-empty left and right sub 
trees. If there are left and right sub trees for each node in the binary tree as shown a complete binary tree. 


Question No: 28 (Marks: 2 ) 

A complete binary tree can be stored in an array. While storing the tree in an array we leave the first 
position (Oth index) of the array empty. Why? 

Answer:- (page 325) 

In case of having a node with left and right children, stored at position i in the array, the left child will be at 
position 2i and the right child will be at 2i+1 position. If the value of 1 is 2, the parent will be at position 2 and 
the left child will be at position 2i1.e. 4 .The right child will be at position 21+1 i.e. 5. we have not started the 
0" position. It is simply due to the fact if the position is 0, 2i will also become 0. So we will start from the 1“ 
position, ignoring the 0". 


Question No: 29 = (Marks: 2 ) 
Give the name of two Divide and Conquer algorithms. 
Answer:- Repeated 


Question No: 30 (Marks: 2 ) 

Give the effect of sorted data on Binary Search. 

Answer:- http://www.cprogramming.com/tutorial/esson18.html 

The binary tree is a fundamental data structure used in computer science. The binary tree is a useful data 
structure for rapidly storing sorted data and rapidly retrieving stored data. 





Muhammad Moaaz Siddig — MCS (2nd) 


mciooAaoi 8-@Gmail.com 


Campus:- Institute of E-Learning & Modern 
Studies (IEMS) Samundari 














Question No: 31 (Marks: 3 
Give any three characteristics of Union by Weight method. 
Answer:- Repeated 


Question No: 32 (Marks: 3 ) 
Here is an array of ten integers: 
5389170264 
Draw this array after the FIRST iteration of the large loop in an insertion sort (sorting from smallest to 
largest). This iteration has shifted at least one item in the array! 


























Answer:- 

5(/3[8[/9[1|7|0/2/6|/4 
I“ step |3|5|8|9/1/7/0|2|6| 4 
2™ step |1/3|5]8|9/7/0|2]6|4 
3 step |1/3/5/7/8/9|0]2]6] 4 
A" step |0/1|3/5/7]8/9/|2]6/4 
5" step |0/1/2]3/5/7/8|/9] 6/4 
6" step |0/1/2/3/5/6/7|/8]9/4 
7" step |0/1|2]3/4/5]6|7]8/9 









































Question No: 33. = ( Marks: 3 ) 
Give your comment on the statement that heap uses least memory in array representation of binary 
trees. Justify your answer in either case. 
Answer:- 
A heap is a complete binary tree, so it is easy to be implemented using an array representation 
It is a binary tree with the following properties:- 
“* Property 1: it is a complete binary tree 
Property 2: the value stored at a node is greater or equal to the values stored at the children 
** From property 2 the largest value of the heap is always stored at the root 


°, 
* 


o 


, 
° 


Question No: 34 (Marks: 5 ) 
Suppose we have the following representation for a complete Binary Search Tree, tell the Left and Right 
child nodes and Parent node of the node D 











Oh de 2 13 5 |}6 |7 |8 |9 | 10} 11} 12) 13 | 14] 15) 16] 17 | 18} 19 | 20 
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Answer: - Repeated 
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Question No: 35 = (Marks: 5 ) 
Explain the following terms: 

1. Collision 

2. Linear Probing 

3. Quadratic Probing 


Answer:- (Page 464-470) 


Collision: 
When two values hash to the same array location, this is called a collision.. 


Linear Probing 
When there is a collision, some other location in the array is found. This is known as linear probing. In linear 


probing, at the time of collisions, we add one to the index and check that location. If it is also not empty, we 
add 2 and check that position. Suppose we keep on incrementing the array index and reach at the end of the 
table. We were unable to find the space and reached the last location of the array. 


Quadratic Probing 


In the quadratic probing when a collision happens we try to find the empty location at index + 142. If it is filled 
then we add 2/2 and so on. 
Quadratic probing uses different formula: 
Use F(i) = i (square of 1) to resolve collisions 
2. If hash function resolves to H and a search in cell H is inconclusive, try 
H+1?,H+22,H +32 


Question No: 36 (Marks: 5 ) 
Here is an array with exactly 15 elements: 
12345 67 8 9 10 11 12 13 14 15. 
Suppose that we are doing a binary search for an element. Indicate any elements that will be found by 
examining two or fewer numbers from the array. 
Answer:- Repeat 


FINALTERM EXAMINATION 2010 


Question No: 27 = ( Marks: 2 ) 
Convert this tree representation of a heap into the corresponding array representation 
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Answer:- 





100 | 19 36 17 3 25 1 2 7 



































Question No: 28 (Marks: 2 ) 
What are different applications of Hashing? 


Answer (page 474) 
** Compilers use hash tables to keep track of declared variables (symbol table). 
“* A hash table can be used for on-line spelling checkers — if misspelling detection (rather than 


correction) is important, an entire dictionary can be hashed and words checked in constant time. 
7 


“* Game playing programs use hash tables to store seen positions, thereby saving computation time if the 
position is encountered again. 


Question No: 29 = ( Marks: 2 ) 

Give the operation names that we can perform on Table abstract data type. 
Answer:- (page 429) 

Insert 

Find 

Remove 


Question No: 30 (Marks: 2 ) 

Give your comments on the statement: 

"Efficiently developed data structures decrease programming effort" 

Answer:- Click here for detail 

Reduces programming effort by providing useful data structures and algorithms so you don't have to write 
them yourself. 

Increases performance by providing high-performance implementations of useful data structures and 
algorithms. Because the various implementations of each interface are interchangeable, programs can be easily 
tuned by switching implementations. 
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Question No: 31 (Marks: 3 ) 

When Hashing is NOT suitable? 

Answer: - (Page 475) 

Hash tables are not so good if there are many insertions and deletions, or if table traversals are needed — in this 
case, AVL trees are better. 


Question No: 32 (Marks: 3 ) 
Give any three characteristics of Union by Weight method. 
Answer: - Repeated 


Question No: 33 ( Marks: 3 ) 
Consider the following Max Heap add node 24 in it and show the resultant Heap, 


Answer: - Repeated 


Question No: 34 = (Marks: 5 ) 
Heapify the elements of the following array (reading from left to right ) into a Min Heap and show that 
Min Heap contents in the form of array as shown below, 






































original array 6 5 |3/9/1 |2 |10 |8 |- 





Answer(page 334) 
Min heap 





Heapified array |1|5 |2 |8 |6 |3 |10 |9 
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Question No: 35 = (Marks: 5 ) 

Here is an array of ten integers: 

5389170264 

Show the first three merging steps for Merge sort on this array. 


Answer:- 
1step ([6_[3 J) To Ii_[7 To 727 [6 Ta 7 


2% step [3 [5 [8 [9 [1 [7 [0 [2 [4 [6 




















3Tstep (3 [5 [8 [9 [1]/]7 [0 [2 [4 Jo 








4" step (113 [8 |5 [9] [2 [6 |7 [0 |4 








5" step [1 [3 [8 [5 [9 [2 [6 [7 [0 |4 












































6"step [1 [2 [3 [6 [7 [8 [0 [5 [4 [9 





Question No: 36 (Marks: 5 ) 
Consider the following sequence of union commands on the set of elements 


{1,2,3,4, 5}: 


OOO © © 


union(4,2) 
union(3,1) 
union(5,4) 
union(5,3) 
Show the result when the unions are performed 


Answer: (Page 396 to398) 
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FINALTERM EXAMINATION 2010 


Question No: 27 ( Marks: 2 ) 
Let’s call the node as a that requires re-balancing. Consider two cases below: 
1) An insertion into right subtree of the left child of a. 

2) An insertion into left subtree of the right child of a. 


Which of the following statement is correct about the above two cases. 

1) The insertion occurs outside (i.e., right to left or left to right) in the above two cases, single rotation can fix 
the balance in these two cases. 

2) The insertion occurs inside ((i.e., right to left or left to right) in these two cases, single rotation cannot fix the 
balance in these two cases. 

Answer: (page 230) 


Insertion occurs on the inside in cases 2 and 3 which a single rotation cannot fix. 


Question No: 28 (Marks: 2 ) 
Represent the following Binary tree using array representation. 


S 
YO © 


Answer:- 





A B C D E 























Question No: 29 (Marks: 2 ) 
Give one example of Hashing 
Answer:- repeat 


Question No: 30 (Marks: 2 ) 

How we can apply Find operation on elements combined through Union operation. 
Answer:- (Page 392) 

We give an element to the find method and it returns the name of the set. 
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Question No: 31 (Marks: 3 ) 
Here is an array of ten integers: 
5389170264 
Draw this array after the FIRST iteration of the large loop in an insertion sort (sorting from smallest to 
largest). This iteration has shifted at least one item in the array! 
Answer:- repeat 


Question No: 32 (Marks: 3 ) 
Consider the following Min Heap apply operation delMin on it and show the resultant Heap, 





Answer:- (page 349) 
It is clear from the definition of min-heap that it should be in the root of the tree. So finding the minimum is very 
easy. Here node 5 is operational node that has to be deleted. 


fy @ @ © 
© 000 @ (2) (3) 


Question No: 33 ( Marks: 3 ) 

Which implementation of disjoint set is better with respect space and why? 

Answer:- (page 405) 

An array that is a single dimensional structure and seems better with respect to space. Suppose we have 1000 set 
members i.e. names of people. If we make a Boolean matrix for 1000 items, its size will be 1000 x 1000. Thus we 
need 1000000 locations for Boolean items, its size will be 1000 x 1000. Thus we need 1000000 locations for 
Boolean values. in case of an array the number of location will be 1000. Thus this use of array i.e. tree like structure 
is better then two dimensional arrays in term of space to keep disjoint sets and doing union and find operation. 


Question No: 34 (Marks: 5 ) 

What is Table ADT? Discuss any two implementations of table ADT. 

Answer (page 427,728) 

The table, an abstract data type, is a collection of rows and columns of information. 
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Implementation of Table 
o Unsorted Sequential Array 
o Sorted Sequential Array 


Question No: 35 (Marks: 5 ) 
Suppose the following numbers are stored in an array ‘BS’: 
32,51,27,85,66,23,13,57 
We apply Bubble sort to array ‘BS’. Show step by step sorting. You have to write only two passes that is 
passing 1 and pass 2. 
Hint; while concern step by step sorting there are 6 passes involved to sort array nums. You have to show 





















































































































all passes 
Answer:- 
Pass one:- 
32 2, 85 66 23 13 57 
Step1 32 Gi__[27-) 
Step2 32 2 5 
Step3 32 =| 27 51 [85 | 23> 
Step4 32 27 51 
Step5 32 27 51 13 
Step6 32 27 51 66 23 13 
Pass two:- 
32 27 51 66 23 13 ay 85 
Step1 51 66 23 13 57 85 
Step2 2 32 51 66 Zo 13 57 85 
Step3 32 27 66 23 66 13 57 85 
Step4 32 27 66 Zo 13 66 5 
Step5 32 27 66 23 13 5 6 85 
Step6 32 27 66 23 13 57 66 85 
Question No: 36 (Marks: 5 ) 


Give two different reasons to explain why the following binary tree is not a heap: 


SI 
fy 
77 46 


fy 
688i II 
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Answer:- (Page 335) 

Above array is not min heap or max heap because every parent node has not minimum or maximum value. 
In max heap, each parent node has a value greater than the value of its left and right child nodes. 

In min heap, each parent node has a value less than the value of its left and right child nodes. 


FINALTERM EXAMINATION 
Fall 2009 


Question No: 31 (Marks: 1 ) 

Describe the conditions for second case of deletion in AVL Trees. 

Answer:- (Page 266) 

This is the case where the parent of the deleted node had a balance of 1 and the node was deleted in the parent’s left 
sub tree. 


Question No: 32 (Marks: 1 ) 
What is Table abstract data type. 
Answer:- repeat 


Question No: 33. ( Marks: 2 ) 
How we can generate a maze .Give an algorithm. 
Answer:- repeat 


Question No: 34 (Marks: 2 ) 
Represent the following Binary tree using array representation. 


y 
Y © 


Answer:- repeat 


Question No: 35 ( Marks: 3 ) 
What is an Equivalent relation? Give any two examples. 
Answer:- repeat 


Question No: 36 (Marks: 3 ) 

"For smaller lists, linear insertion sort performs well, but for larger lists, quick sort is suitable to apply." Justify 
why? 

Answer:- repeat 
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Question No: 37 ( Marks: 3 ) 

How many leaf and non-leaf nodes are present in a complete binary tree if its depth is 7? 
Answer:- (Page 125) 

Leaf Node = 24d = 247 = 128 

Non leaf Nodes = 24d -1 = (27) -1 = 128—1= 127 


Question No: 38 (Marks: 5 ) 
Remove the smallest element from the following array which represents a min-heap. 



































original min-heap |1 |3 {2 |5 |4 |8 |9 10 | 7 








and show the resultant heap in the form of array as shown below, 
Answer:- repeat 


Question No: 39 (Marks: 5 ) 
Here is an array with exactly 15 elements: 
12345 67 8 9 10 11 12 13 14 15. 
Suppose that we are doing a binary search for an element. Indicate any elements that will be found by 
examining two or fewer numbers from the array. 
Answer:- repeat 


Question No: 40 (Marks: 10 ) 
(a) Write C++ algorithm for Binary Search 


Answer:- (Page 125) 
int isPresent(int *arr, int val, int N) 


{ 

int low = 0; 

int high = N - 1; 
int mid; 


while ( low <= high ) 


{ 

mid = ( low + high )/2; 
if (arr[mid] == val) 
return 1; // found! 

else if (arr[mid] < val) 
low = mid + 1; 

else 

high = mid - 1; 


return Q; // not found 
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b) Consider the following array of values; show how the binary search algorithm would find the value -5. 
Clearly show/explain your work; that is, show the values of start, end, etc. for each step of the algorithm. 


0 | -15 | 
11-5 4 
21 0 | 
3 1 #7 | 
41 43 1 
5 1 16 1 
61 27 41 
7 1 30 4 
se 1 42 1 


Answer : (page 437) 
Value < mid 

Value = -5 
Mid=(0+8)/2=4 
Low=0 

High=mid -1=4-1 






































-15 -5 0 e 13 16 2d 30 42 
0 1 2 2 4 5 6 7 8 
low high mid 


Starting from the low which is -15.now compare the -5 form the next index which is at position 1. 




































































-15 -5 0 ic 13 16 ZT 30 42 
0 1 2 2 4 5 6 7 8 
low high mid 
-15 -5 0 7 13 16 21 30 42 
0 1 2 3 4 5 6 i 8 
low high mid 





Muhammad Moaaz Siddig — MCS (2nd) 


Campus:- Institute of E-Learning & Modern 
Studies (IEMS) Samundari 




















Question No: 41 (Marks: 10 ) 
Show the result of following sequence of instructions 


Union(1,2) 

Union(3,4) 

Union(3,5) 

Union(1,7) 

Union(3,6) 

Union(8,9) 

Union(1,8) 

Union(3,10) 

Union(3,11) 

Union(3,12) 

Union(3,13) 

Union(14,15) 

Union(16,17) 

Union(14,16) 

Union(1,3) 

Union(1,14) 

When the unions are performed by height 
Note: You have to show only Final tree, No need to show all steps. 


Answer:- 
Solve it yourself; take help from previous same question that I have solved in page 12 of this file. 


FINALTERM EXAMINATION 
Fall 2009 


Question No: 31 (Marks: 1 ) 

If a Binary Tree has N internal nodes what are the no. of external nodes in it. 
Answer:- (Page 304) 

The No. of external nodes will be N+1 


Question No: 32 (Marks: 1 ) 

What is meant by Symmetry in equivalence relations? 

Answer:- (Page 387) 

Symmetry in equivalence relations mean for all elements x and y, x R y if and only if y R x 


Question No: 33. ( Marks: 2 ) 
How heap sort works to sort a set of data. 
Answer:- Repeated 
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Question No: 34 = (Marks: 2 ) 
How we can apply Find operation on elements combined through Union operation. 
Answer:-Repeated 


Question No:35 = (Marks: 3 ) 
How we can use concept of equivalence relations to generate a Maze. 
Answer:-Repeated 


Question No: 36 (Marks: 3 ) 

Suppose we are sorting an array of eight integers using a some quadratic sorting algorithm. After four 

iterations of the algorithm’s main loop, the array elements are ordered as shown here: 
2457813 6 

Which statement is correct? (Note: Our selectionsort picks largest items first.) 


A. The algorithm might be either selection sort or insertion sort. 

B. The algorithm might be selection sort, but it is not insertion sort. 
C. The algorithm is not selection sort, but it might be insertion sort. 
D. The algorithm is neither selection sort nor insertion sort. 

E. None of these. 


Answer:- 
C. The algorithm is not selection sort, but it might be insertion sort. (Correct) 


Question No: 37 = ( Marks: 3 ) 
How many leaf and non-leaf nodes are present in a complete binary tree if its depth is 7 ? 
Answer:- repeat 


Question No: 38 (Marks: 5 ) 

If we insert a new element into an AVL tree of height 4, is one rotation sufficient to re-establish balance? 
Justify your answer. 

Answer:- 

No, one rotation is not always sufficient to re-establish balance. For example, consider the insertion of the shaded 
node in the following AVL tree: 


Sy 





Though the original tree was balanced, more than one rotation is needed to restore balance following the insertion. 
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This can be seen by an exhaustive enumeration of the rotation possibilities. 
The problem asks for a tree of height 4, so we can extend the above example into a larger tree: 





Question No: 39 (Marks: 5 ) 

Write down the C++ code from Selection Sort Algorithm. 
Answer:- (Page 480) 

void selectionSort(int *arr, int N) 

{ 
int posmin, count, tmp ; 

for (count=0;count<N;count++) 
{ 
posmin = findIndexMin(arr, count, N) ; 
tmp=arr[posmin] ; 
arr[posmin]=arr[count] ; 

arr[count]=tmp ; 

} 

} 

int findIndexMin (int *arr, int start, int N) 
{ 

int posmin=start ; 

int index ; 

for(index=start; index < N; index++) 

if (arr[index]<arr[posmin]) 
posmin=index ; 

return posmin ; 


} 


FINALTERM EXAMINATION 2011 (Feb) 


1- 3 important characteristics of skip list. 
Answer ; (page 442) 
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Search and update require linear time 

Fast Searching of Sorted Chain 

Provide alternative to BST (binary search trees) and related tree structures. 
Balancing can be expensive. 


Relatively recent data structure: Bill Pugh proposed it in 1990 


2- Drawback of using array to store BST. 


Answer:- (Page 21) 
The drawback of using is the limitations that array being of fixed size can only store a fixed number of elements. 
Therefore, no more elements can be stored after the size of the array is reached. 


3-examples of hashing. 
Answer:- repeat 


4-c++ code to add node in doubly link list. 

Answer ; (page 40) 

class Node { 

public: 

int get() { return object; }; // returns the value of the element 

void set(int object) { this->object = object; }; // set the value of the element 
Node* getNext() { return nextNode; }; // get the address of the next node 
void setNext(Node* nextNode) // set the address of the next node 

{ this->nextNode = nextNode; }; 

Node* getPrev() { return prevNode; }; // get the address of the prev node 
void setPrev(Node* prevNode) // set the address of the prev node 

{ this->prevNode = prevNode; }; 

private: 

int object; // it stores the actual value of the element 

Node* nextNode; // this points to the next node 

Node* prevNode; // this points to the previous node 

iB 

5-What you conclude from the running time analysis of disjoint sets. 
Answer (page 405) 

We conclude that: 


* union is clearly a constant time operation 
* Running time of find(i) is proportional to the height of the tree containing node 1. 
This can be proportional to n in the worst case (but not always). 


> ate 


om 


o, 
~~ 


, 
~~ 


Goal: Modify union to ensure that heights stay small 


6-explain how heap sort work. 
Answer:- repeat 
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7-what is c++ template. 

Answer:- (page 75) 

A template is a function or class that is written with a generic data type. when a programmer uses this function or 
class the generic data type is replaced with the data type needed to be used in the template function or in the 
template class. We only give the data type of our choice while calling a template function or creating an object of 
the template class. The compiler automatically creates a version of that function or class with that specified data 


type. 


8-explain and write the code for union and find operation of parent array in disjoint sets. 
Answer:- (page 399) 


Find (i) 


This loop is used to find the parent of an element or the name of the set that contains that element. 


// traverse to the root (-1) 
forG=i; parent[j] >= 0; j=parent[j]) 


return j; 


Union (i, j ) 
Now let’s see the code for the function of union. Here we pass two elements to the function union. The union 
finds the roots of 1 and j. If i andj are disjoint sets, it will merge them. Following is the code of this function. 


root_i = find(i); 

root_j = findq); 

if (root_i != root_j) 
parent[root_j] = root_i; 


In the code, we see that at first it finds the root of tree in which i exists by the find(z) method and similarly finds 
the root of the set containing j by find(j). Then there is a check in if statement to see whether these sets (roots) are 
same or not. If these are not the same, it merges them in such a fashion that the root i is set as the parent of root /. 
Thus, in the array where the value of root j exists, the value of root i becomes there. 


FINALTERM EXAMINATION 2011 (Feb) 


Question No: 41 (Marks: 2) 
Convert the given infix form to postfix form. 
A+B/C-D’E-F 


Answer:- (Page 66) 
AB+C/D-EF -* 
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Question No: 42 (Marks: 2) 
How we can implement Table ADT using Linked List 
Answer:- repeat 


Question No: 43 (Marks: 2) 
If we allow assignment to constants what will happen? 
Answer:- repeat 


Question No: 44 (Marks: 2) 
How heap sort works to sort a set of data. 
Answer:- repeat 


Question No: 46 (Marks: 3) 

Give your comment on the statement that heap uses least memory in array representation of binary 
trees. Justify your answer in either case. 

Answer: - repeat 


Question No: 47 (Marks: 3) 
How we can use concept of equivalence relations to generate a Maze. 
Answer: - repeat 


Question No: 48 (Marks: 3) 

"For smaller lists, linear insertion sort performs well, but for larger lists, quick sort is suitable to apply." 
Justify why? 

Answer: - repeat 


Question No: 49 (Marks: 5 ) 

695041732 

Show the first five merging steps for Merge sort on this array. 
Answer:- repeat (Also see the same solution above) 


Question No: 50 (Marks: 5) 
What is Disjoint Sets? Explain with an example. 
Answer:- (Page 388) 


Disjoint sets - Two sets are disjoint if they have no elements in common. 

Example:-Suppose there are many people around you. How can we separate those who are related to each other in 
this gathering? 

We make groups of people who are related to each other. The people in one group will say that they are related to 
each other. Similarly we can have many groups. So every group will say that they are related to each other with 
family relationship and there is no group that is related to any other group. The people in the group will say that 
there is not a single person in the other group who is related to them. 
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Question No: 51 (Marks: 5) 

Write the code of the perculateDown() function and also comment it. 
Answer:- (page 369) 

template <class eType> 

void Heap<eType>::percolateDown( int hole ) 


{ 

int child; 

eType tmp = array[ hole ]; 

for( ; hole * 2 <= currentSize; hole = child ) 


{ 

child = hole * 2; 

if( child != currentSize && array[child+1] < array[ child ] ) 
child++; // right child is smaller 

if( array[ child ] < tmp ) 

array[ hole | = array[ child ]; 

else break; 


} 
array[ hole ] = tmp; 


Question No: 52 (Marks: 5) 

Here is an array with exactly 15 elements: 

1234567891011 12131415. 

Suppose that we are doing a binary search for an element. Indicate any elements that will be found by 
examining two or fewer numbers from the array. 

Answer:- repeat 


FINALTERM EXAMINATION 2011 


Question No:1 
How we can implement Table ADT using Linked List (marks 2) 
Answer: - repeat 


Question No:2 
which three basic operations are performed on AVL trees (mark 3) 
Answer:- (page 457) 

“+ Insert 


, 


“ Delete 


>, 


“* search 


Question No:3 
write down the c++ code to implement insertion sort algorithm (5) 
Answer: - repeat 
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Question No:4 
Give the name of three Divide and Conquer algorithms. (marks 3) 
Answer: - repeat 


Question No:5 

Here is an array of ten integers: 

5389170264 

Draw this array after the FIRST iteration of the large loop in an insertion sort (sorting from smallest to 
largest). This iteration has shifted at least one item in the array! (marks 3) 

Answer: - repeat 


FINALTERM EXAMINATION 2011 


Question No: 1 

For smaller list linear insertion sort is perform well but for large list Quick sort suitable to apply/justify 
Answer:- 

Since for smaller lists number of comparisons and interchange (if needed) decreases radically in insertion sort 
than quick sort. For larger lists, opposite occurs in both sorting techniques. 


Question No: 2 

Here is a array of exactly 15 elements 

12345 6 7 8 9 10 11 12 13 14 15 

Suppose that we are doing a binary search for an elemnt .Indicate any element that will be found by 
examining two or fewer number from the array (5 mrks) 

Answer:- repeat 


Question No: 3 

Write the applications of heap. 

Answer:- (page 84) 

The stack and heap are used in function calls. When we allocate memory dynamically in our programs, it is 
allocated from the heap. The use of priority queue with the help of heap is a major application. The priority queue is 
itself a major data structure, much-used in operating systems. Similarly priority queue data structure is used in 
network devices especially in routers. Heap data structure is also employed in sorting algorithms. 


Question No: 4 
Write down the c++ code for selection sort (5 marks) 
Answer: - repeat 


Question No: 5 

Write the application of binary search tree 

Answer: - (page 369) 

The searching and sorting operations are very common in computer science with the help of binary search tree. 
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Question No: 6 
Write the about disjoint set? 
Answer: - repeat 


Question No: 7 
Heapify the elements of the following array (reading from left to right ) into a Min Heap and show that 
Min Heap contents in the form of array as shown below, 






































original array 6 5 |3/9/1 |2 |10 |8 |- 
Answer: - repeat 





Question No: 8 
Represent the following binary tree in array 


Answer: - repeat 
FINALTERM EXAMINATION 2011 


Question No: 1 
Write the any two operation of linked list that perform their function in one step. 2Marks 
Answer: - (page 38) 
“+ Add 
*° Remove 
x Find 


, 


, 


Question No: 2 
Represent the following binary tree in array. 2Marks 


Answer: - repeat 
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Question No: 3 

Write different type of hashing. 2 Marks 

Answer: - Click here for detail 

Data structures that employ hashing methods to store keys (and information possibly associated to it) are denoted 
as hashing types. 


Question No: 4 
Give the table name that that we can on table abstract datatype. 3mark 


Question No: 5 
Explain the process of Deletion ina Min-Heap 3 Marks 
Answer: - repeat 


Question No: 6 
What is skip list? 3 Marks 
Answer: - repeat 


Question No: 7 
What we can conclude from the running time array of disjoint set. 5 Marks 
Answer: - repeat 


Question No: 8 
77, 33,44,11,88,22,66,55 sort the following array using insertion algorithm. 5 Marks 
Answer: - See the same solution above 


Question No: 9 
What is disjoint set? 5 Marks 
Answer: - repeat 


Question No: 10 

Suppose we have the following representation for a complete Binary Search Tree, tell the Left and Right 

child nodes and Parent node of the node D ( Marks: 5) 

Pe es eco dar etalwis elt iiste 
4 














Oil. 2 [3 5 |}6 |7 |8 |9 | 10} 11} 12) 13 | 14} 15) 16] 17 | 18} 19 | 20 




































































Answer: - repeat 


FINALTERM EXAMINATION 2011 


1. Give one example of Hashing. (2) 
Answer: - repeat 
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2. Give the operation names that we can perform on Table abstract data type. (2) 
Answer: - repeat 


3. Define Linked List in your own words. (2) 
Answer: - repeat 


4. Convert this tree representation of a heap into the corresponding array representation. 


(2) 


Answer: - repeat 


5. Here is an array of ten integers: 
5 3 8 9 1 7 2 6 4 
Draw this array after the FIRST iteration of the large loop in an insertion sort (Sorting from 
smallest to largest). This iteration has shifted at least one item in the array. (3) 
Answer:- repeat 


6. Which implementation of disjoint set is better with respect space and why? (3) 
Answer: - repeat 


7. Consider the following Min Heap apply operation delMin on it and show resultant Heap. 
(3) 





Answer: - repeat 
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8. Which is Dynamic Equivalence Problem with an example? (5) 

Answer: - (page 395) 

We are using sets to store the elements. For this purpose, it is essential to remember which element belongs to 
which set. We know that the elements in a set are unique and a tree is used to represent a set. Each element in 
a tree has the same root, so the root can be used to name the set. The item (number) in the root will be unique 
as the set has unique values of items. We use this root as the name of set for our convenience. Otherwise, 
we can use any name of our choice. So the element in the root (the number) is used as the name of the set. 
The find operation will return this name. Due to the presence of many sets, there will be a collection of trees. In 
this collection, each tree will be representing one set. If there are ten elements, we will have ten sets initially. 
Thus there will be ten trees at the beginning. In general, we have N elements and initially there will be N 
trees. Each tree will have one element. Thus there will be N trees of one node. Now here comes a definition for 
this collection of trees, which states that a collection of trees is called a forest. 

The trees used for the sets are not necessarily binary trees. That means it is necessary that each node 
should have a maximum of two children nodes. Here a n may have more than two children nodes. 

To execute the union operation in two sets, we merge the two trees of these sets in such a manner that 
the root of one tree points to the root of other. So there will be one root, resulting in the merger of the 
trees. 

In the find operation, when we call find (x), it helps us to know which set this x belongs to. Internally, we find 
this x in a tree in the forest. When this x is found in a tree the find returns the number at root node (the name of the 
set) of that tree. 


9. Here is an array of ten integers 

5 3 8 9 1 7 0 2 6 4 
Sort the array by using selection sort algorithm and show content of array after each step. (5) 
Answer: - repeat 


10. Consider the following Binary tree and Delete the key 29, 35, 75 and 60 only. Show the 
resultant tree after deleting these keys. (5) 
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Answer:- 


11. Suppose we have the following representation for a complete Binary Search Tree, tell the 
Left and Right child nodes and Parent node of the Node D 





A|B{I|C|D/E/|F/G|H{|I |J |K|LI|M|IN |/O/{P |Q/R{S 
0);1 /2/3 |4 45 |6 |7/8 |9 J1 |1 {1 51-41 «41 
0 |1 |2 (3 [4 {5 (6 |7 |8 [9 











— 
—_ 
— 
— 

So Ns 




































































Answer: - repeat 
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1) For a perfect binary tree of height 5, what will be the sum of heights of nodes? 2marks 


Answer: - repeat 


2) Properties of equivalence class. 


Answer: - repeat 


3) Two ways for the implementation of Queue data structure. 
Answer: - (Page 89, 91) 
1, Implementation of queue using linked list 


2: Implementation of queue using Array. 


4) Worst case of selection sort 
Answer: - Click here for detail 


The worst case occurs if the array is already sorted in descending order. Nonetheless, the time require by 
selection sort algorithm is not very sensitive to the original order of the array to be sorted. 


6) “is a sibling of” set of all human beings is equivalence relation or not? Explain. 
Answer: (Page 387) 


Yes it is an equivalence relation 











First rule is reflexive i.e. for all element x [) S, x R x. Suppose that x is Haris so Haris R Haris. This is true because 
everyone is related to each other. Second is Symmetry: for all elements x and y, x R y if and only if y R x. Suppose 
that y is Saad. According to the rule, Haris R Saad if and only if Saad R Haris. If two persons are related, the 
relationship is symmetric 1.e. if I am cousin of someone so is he. Therefore if Haris is brother of Saad, then Saad is 
certainly the brother of Haris. The family relationship is symmetric. This is not the symmetric in terms of respect but 
in terms of relationship. The transitivity is: “for all elements x, y and z. If x R y and y R z, then x R z’. Suppose x is 
Haris, y is Saad and z is Ahmed. If Haris “is related to” Saad, Saad “is related to” Ahmed. We can deduce that Haris 
“is related to” Ahmed. This is also true in relationships. If you are cousin of someone, the cousin of that person is 
also related to you. He may not be your first cousin but is related to you. 





7) Linked memory 
(Answer: Page 18) 


Linked memory is a memory in which the various cells of memory are not located continuously. In this process, 
each cell of the memory not only contains the value of the element but also the information where the next element 
of the list is residing in the memory. It is not necessary that the next element is at the next location in the memory. It 
may be anywhere in the memory. We have to keep a track of it. 

Thus, in this way, the first element must explicitly have the information about the location of the second element. 
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Similarly, the second element must know where the third element is located and the third should know the position 
of the fourth element and so on 


8)3598170264, draw after the 1" iteration of large loop in a selection sort (smallest to largest) 


Answer: - repeat 


9) Union commands 1, 2, 3, 4, 5 union(4,2),union(3,1),union(5,4) 5 marks 


Answer: - repeat 


10) Code for removing an element from a linked list data structure if it is implementation by using linked 
memory methods. 


Answer: Page 34 


void remove() { 

if( currentNode != NULL && currentNode != headNode) { 
lastCurrentNode->setNext(currentNode->getNext()); 
delete currentNode; 

currentNode = lastCurrentNode->getNext(); 

size--; 

} 
b 
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